Skip to content

Conversation

@Niklan
Copy link
Contributor

@Niklan Niklan commented Jan 29, 2025

I'm not sure if the property should be explicitely declared. It works fine without it. Most likely, it comes from PHPStorm's stubs. Also, I'm not sure if it should be:

@phpstan-assert-if-true DOMNamedNodeMap $this->attributes

to be more specific, or is it fine with !null?

This PR fixes an issue where PHPStan does not understand chained calls, as discussed here: phpstan/phpstan#12495 (comment)

    if ($node->hasAttributes()) {
      foreach ($node->attributes->getIterator() as $attribute) {
  22     Cannot call method getIterator() on DOMNamedNodeMap|null.  
         🪪  method.nonObject   

@ondrejmirtes ondrejmirtes merged commit f2acf14 into phpstan:2.1.x May 5, 2025
430 of 431 checks passed
@ondrejmirtes
Copy link
Member

Thank you.

@VincentLanglet
Copy link
Contributor

For the record, it now report DomElement::hasAttributes as always true.
https://phpstan.org/r/a2e4727f-a66f-4aee-9d62-18973c8984a8

I think it's because of the bad type of PHPStorm stubs.
I tried JetBrains/phpstorm-stubs#1741

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants